i= = i = x | 
1) Li t q 
2 fom 
J Oia 


o'r 
» we 
Gar ee 
eo Free 
= fae 
ies 





CONTENTS 


PURPOSES: 6.08. seen "6 4 
CONVENTIONS. . . 2 « «© « 
PROCEDURES . .... e « 

Verify Key Punching. . 


ee, te 
a 


Verify Legality of 


Addresses 


In All Program Cards. 


Verify Legality of Operation Codes. . . 2... « 


Verify Legality of “m™ Addresses In Instruction Cards. 


si hall 


Verify Legality of 


Addresses In Instruction Cards, 


Verify Continuity of “c" Address to “a“ Address... . 


Verify Insertion of 22 Tests of HSR Buffer...... 


CONSIDERATIONS ..... 


ana D> ON OO 


10 


I, 


Il. 


PURPOSE 


A, To suggest methods of analyzing the clerical accuracy of machine 
coded problems for the UNIVAC Solid-State 90 using conventional 
Punched-Card equipment prior to program testing on the computer. 

B. To establish standards to aid in program testing at the computer 
and to assure efficient use of time at program testing facilities. 

CONVENTIONS 
A. To aid in developing a uniform testing procedure, the illustrated 


Coding Chart (U1711), Memory Chart (U1710) and Program Card form 
are recommended, 


~ Coding Chart Card | 
Name Columns Purpose 


Page No. 11 - 13 A sequential number to identify 
the page of coding. 


Line No. 14 - 15 To identify the line of coding 
Within the page. 
16 


Suffix 
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Instruction 17 - 20 
Location 
(a) 
Operation Code 
vi 
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Optional field. May be used 
to designate an insertion, 






Designates the memory location 
where the instruction/constant 
is to be stored, 







Designates the machine opera- 
tion to be performed. (2 MSD 
of a constant) 








Designates the memory location 
of the data to be handled, (4 
next MSD of a constant) 






Data Location 23 - 26 
(m) 


Next Instruction/27 - 30 
(c) 






Designates the memory location 
of the next instruction to be 
executed. (4 LSD of a 
constant ) 








Designates how the instruction/ 
constant is to be stored. 
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. THE NAME OF THE APPLICATION 
. THE NAME OF THE PROGRAM 


. CARD NUMBER (for use in assembly systems) 


. ROUTINE DESIGNATION (for use in assembly systems) 


. SEQUENCE NUMBER (for use in assembly systems and for 


those who prefer to use a straight sequence number rather 


than a page and line reference) 


. PAGE NUMBER (used to designate the page where reference 


is made to this instruction) 


. LINE NUMBER (used with Page Number to designate a specific 


line on which reference is made to this instruction) 
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Some programmers may prefer to use a Straight Sequence 
number rather than a Page and Line reference. In this 


event the actual Page (A) and preprinted Line (B) numbers 


are ignored and the Sequence number is written in the 


reference area under the captions Page and Line. Sequence 
number is punched in card columns 11 through 15. 


1. TRANSLATE AND STORE + 2. TRANSLATE AND STORE — 3. STORE UNPRIMED + 4. STORE UNPRIMED — 5, STORE PRIMED+ 6. STORE PRIMED — 
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NEW UNIVAC® MAGNETIC AMPLIFIER, SOLID-STATE COMPUTER - MEMORY CHART 


PROGRAM: 


CUSTOMER: 


PAGE: 


APPLICATION: 


BAND: 


BAND: 
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location write the reference, either Page/Line or Sequence 
location to more than one instruction/constant and aid the 


number, opposite the word designation on the memory chart. 


Each time an Instruction or Constant is assigned a memory 
This w 


programmer in selecting unused locations. 
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U 1710 


B, To facilitate automatic sorting of instruction and constant 
words it is suggested that blocks of Page and Line or Sequence 
numbers be assigned as follows: 


1, A major block for all instruction words, 


2. A minor block for all constants which are instruction 
words, 


3. A second minor block for all constants which are not 
instruction words, 


C. Consideration should be given to the advantages of punching a 
One (1) in some unique position of all program cards to estab- 
ish a card count control. 


D, To aid in the automatic analysis it will be helpful to prepare 
and verify Program Testing Decks. (Note that Band 1, words 
0000 through 0199, is presently reserved for control routines) 
Three program testing decks will be required: 


1, PT-1 - 4800 cards with memory locations 0200 through 
4999 punched in the “a™ location, card columns 
17 aay 20, 


2. PT-2 - 4800 cards with memory locations 0200 through 
4999 punched in the "m" location, card columns 
23 = 26, 


3. PT-3 - 4800 cards with memory locations 0200 through 
4999 punched in the "c" location, card columns 
oT — 30. 


III, PROCEDURES 


A. Verify Key Punching 


1, List all the Program Cards on the tabulator in the same 
order as the coding appears on the coding charts. Set 
sub-total control on Page number (columns 11 - 13) to 
obtain space between pages. 


2, Verify to original coding charts, Save this list and 
manually post all corrections made as a result of sub- 
sequent analysis, 


B. Verify legality of "a" addresses in all program cards. 


1. Sort all program cards, instructions/constants, to "a 
address, card columns 17 - 20, 


2. Merge program testing deck # 1 into the program deck. 
Segregate duplicates and non-matching cards from the 
program deck. A 315 or 319 Collator will: 


(a) Segregate program cards if more than one in- 
struction/constant was assigned to a memory 
location, 


ee ee 


(b) Segregate invalid "a™ addresses. 


(c) Interfile a blank "a" address card into the 
program deck for each location not used, 


3. List on tabulator, print all data. This listing will 
serve to replace Memory Chart (U1710) by providing 
complete information relative to the line of coding and 
provide a space opposite unused words for noting addi- 
tional instructions, if necessary. 


C. Verify legality of Operation Codes 


1, Sort instruction and constant cards which represent in- 
structions to Operation Code, card columns 21 - 22, 


2, List on tabulator, print all data. Set sub-total con- 
trols on Operation Code to obtain spacing between codes. 


(a) Scan list visually for illegal Operation Codes. 


(b) Check Operation Codes which should be blank in 
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m or c locations, 


(c) Check for correct stacker location in 47 and 57 
codes, ~ 


(d) In the 81,96,11 and 46 codes check to be sure 
that the "“c" address is no earlier than the re- 
commended location for minimum latency. 


(e) In the same 81,96,11 and 46 codes check to be 
sure that the instruction address is no later 
than that recommended for minimum latency. 
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(f) Scan shift codes for correct location of “"n 


D. 


(g) Optional: if word times have been punched in 
the cards and if a 330 Calculating Punch, 
UNIVAC 60/120 or UNIVAC Solid-State 90 is avail 
able, calculations may be made to determine the 
word times between instruction address and the 
"ce" address to check the word times determined 
by the programmer, 


(h) If a UNIVAC 60/120 or UNIVAC Solid-State 90 is 
available, it may also be desirable to program 
to determine whether the "“c™ is spaced from the 
“m" address by at least the execution word 


times, 
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Verify legality of “m addresses in instruction cards 


L, 


Sort instruction and constant cards which represent in- 
structions to Page and Line, card columns 11 - 15, 
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(minor) then to "m" address, card columns 23 - 26 (major). 


Merge program testing deck # 2 into the program deck. 
Segregate non-matching cards from the program deck, A 
315 or 319 Collator will: 


ih A 


(a) Segregate invalid "m" addresses. 


(b) Interfile a blank “m" address card into the 
program deck for each memory location not used 
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as mM. 


List on tabulator, print all data. Set sub-total con- 


trols on two most significant digits of ‘m’ to obtain 
spacing. This listing will group all "m™ references to 
memory by Page and Line or Sequence number and provide a 


single blank space opposite each memory location not used. 


List on tabulator all program cards which were segregated 
on the merge operation, These cards will be: 


register addresses 
shifts of 10 positions 
addresses in machine code, 

(a) Check carefully all instances where the same "“m" 
address is in more than one card. Duplicates 
may be for legal multiple use of the same op- 
erand or may indicate erroneous coding. Use 
Page and Line or Sequence number to refer to 
coding charts. 


E. 


(by Check “m" addresses in interlace positions to 
be sure that correct addresses have been used 
for first read, second read, print and punch 
interlace words, 


Verify legality of "c" addresses in instruction cards 


1, 


Sort instruction and constant cards which represent in- 
structions to Page and Line, card columns li - 55, 


(minor) then to "c"™ address, card columns 27 - 30 (major). 


Merge program testing deck # 3 into the program deck. 
Segregate non-matching cards from the program deck. A 
315 or 319 Collator will: 
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(a) Segregate invalid "c™ addresses. 


(b) Interfile a blank "c" address card into the pro- 
gram deck for each memory location not used as 
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List on tabulator, print all data. Set sub-total con- 
trols on the two most significant digits of “c" to obtain 
spacing. This listing will group all “c" references to 
memory by Page and Line or Sequence number and provide a 


Single blank space opposite each memory location not used, 


List on tabulator all program cards which were segregated 
On the merge Operation, These cards will be register 
addresses, 


Check carefully all instances where the same "c" address 
is in more than one card, Duplicates may indicate a 
legal condition, as where the “c" address concerned is 
the point to which a number of instructions jump, or may 
indicate erroneous use of same "c"™ address in two or 
more instructions. Use Page and Line or Sequence numbers 
to refer to coding charts. 


Check "“c™ addresses for all words which are in bands used 
as interlaces in the program to insure that the correct 

location has been used for first read, second read, print 
and punch data. For example, if an instruction refers to 
a "c" address which is supposed to be in first read words, 
determine that the address actually is in first read inter- 
lace position, 


ee. te 


F, Verify continuity from "“c"“ address to “a" address 


1. 


26 


3. 


4. 


Remove all PT-3 cards from program cards used in the "c 
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verification above, 
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Keeping the program cards in ‘c’ address order, reproduce 
the instruction cards gang punching into the reproduced 

cards a carriage line space control hole and some print- 
able position to identify each card as being part of the 
reproduced deck, 


Sort reproduced deck (PT-4) on “a™ address, card columns 


17 haa 20, 


On a 319 Collator merge the program cards ahead of 


matching cards in the reproduced deck, Compare the “"c 
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address in the program deck, card columns 27 - 30 to the 
"a" address in the reproduced deck, card columns 17 - 20, 
Segregate non-matching cards from both decks, 


J. List all cards on the tabulator, print all data, Set 
carriage line spacing to 1/1. 


6. 


For nearly every address 


we 
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of a true instruction card 


there should be a matching instruction address, ("a"), 
in the reproduced card listed on the line below. The 
carriage line space control hole separates the related 
pair for reading convenience. 


(a) 


(b) 


Check all cases where a single line appears for 
either the original deck or reproduced deck. 

Be sure to print the identification of the re- 
produced deck, 


Single lines may indicate constants, or may 
indicate a “c" address reference to an instruc- 
tion address which is not represented by a card, 
Or may indicate a register which is used to 
contain the next instruction, or may indicate 
one of the addresses involved in a comparison 
Operation, 


G. Verify insertion of 22 test of HSR buffer 


l, 


Return to original coding charts. Be sure that all 
changes from preceding procedures have been made on the 
Chart and in the program cards, 
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2. For each type of input card and every branching condition 
possible from the card, add up the word times on a 
Remington adding machine or "99" calculator from each 42 
test in the instruction sequence to the next applicable 
42 test. Check accumulated word times to insure that the 
interval from one 42 test (including executing that test) 
up to the next 42 test does not exceed 1000 word times 
(5 drum revolutions). Save the printed copy to file with 
the coding papers, identified by input condition tested. 
Note that the instruction address can be entered at the 
left of the word times, allowing four total positions for 
the word times, thus providing reference to the instruc- 
tion address related to the word times figure. 


IV. CONSIDERATIONS 


A. 


When frequent use is made of the standard High-Speed Reader 
Reserve Storage Routine and Read-Punch Unit Backup Punching 
Routine, it may be desirable to include the complete coding in 
the three program testing decks. 


Some programmers will find it advantageous to punch a designa- 
ting position into each of the program testing decks to iden- 
tify each memory location used in an interlace, 


It will always be desirable to rerun each of the lists de- 
scribed above when final corrections have been made. These 
lists should become part of the Run Book, Corrected lists will 
insure efficient use of time when debugging at the computer. 





uNIVACc The FIRST Name in Electronic Computing Systems 


omer, 
ha? 7h1,0 ake 


